<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <button>来个好玩的</button>
    <button>下去吧</button>
    <hr>

    <div id="root"></div>

    <script src="../js/react.development.js"></script>
    <script src="../js/react-dom.development.js"></script>
    <script src="../js/babel.min.js"></script>

    <script type="text/babel">
        class Video extends React.Component{
            //渲染
            render(){
                console.log('3-渲染中...');
                return <video controls height="500" src="http://api.xiaohigh.com/video/random"></video>
            }
            //1. 构造方法
            constructor(props){
                super(props);
                console.log('1-构造方法');
                //构造方法中, 可以得到 props 数据, 如果不接收 props 则在构造方法里得不到props数据
            }

            //2. 组件将要挂载
            componentWillMount(){
                console.log('2-组件将要挂载');
            }

            //4. 组件挂载完成
            componentDidMount(){
                console.log('4-组件挂载完毕');
            }
        }

        //获取两个按钮
        let btns = document.querySelectorAll('button');

        //第一个按钮单击事件
        btns[0].onclick = function(){
            //挂载 渲染组件
            ReactDOM.render(<Video test="测试" />, document.querySelector("#root"));
        }

        //第二个按钮单击事件
        btns[1].onclick = function(){
            //卸载组件  unmount 卸载  component 组件  at 在   node 节点
            ReactDOM.unmountComponentAtNode(document.querySelector("#root"));
        }
    </script>
</body>
</html>